IV 
HARDWARE OPERATION 



The material contained in this section describes the hardware 
for the Central Processor Unit (CPU). 

4. 1 MASTER CLOCK 

The CPU clock (see Figure 4-1) is a two-phase delay line 
clock that provides one variable and two fixed clock pulses- The 
variable clock pulse is called Master Clock (MCLOCK); the fixed 
clock pulses are called Data Cycle Now Permit (MCDCNP) and Local 
Register Valid (MLRVLD) . All three clock pulses are generated by 
delay lines which are hereafter referred to as the clock cycle 
generator - 

A Master Clock pulse is composed of an 80-nanosecond positive 
period and a variable length negative period. The negative in- 
tervals range from 80- to 240-nanoseconds in duration and are 
usually selected by bits 20 and 21 of the control store word (CK 
Field). Combining the selected negative period with the 80- 
nanosecond positive period produces one complete Master Clock 
cycle with an overall clock speed as indicated below. 
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A Data Cycle Now Permit pulse indicates that the Megabus ad- 
dress lines are valid; a Local Register Valid pulse indicates 
that the contents of the control store data register are valid. 

The roaster clock logic can be divided into the following 
three areas : 

• Clock initialization network 

• Clock stall network 

• Clock cycle generator. 

4.1.1 Clock Initialization Network 

The clock initialization network monitors the Megabus for a 
power-up sequence to initialize the CPU and the master clock, and 
to initiate the necessary CPU housekeeping operations when a 
power supply malfunction occurs. It performs these functions in 
conjunction with the clock stall network. 

4.1..2 Clock Stall Network 

The clock stall network momentarily stalls the clock when 
additional time is needed to complete one of the following CPU 
or firmware generated functions: 

• A clock initialization that occurs during the CPU power- 
up sequence . 

• A firmware initiated Megabus cycle to which no responding 
bus activity is expected (e.g., a memory write operation) - 
The clock remains stalled until the selected unit acknowl- 
edges or rejects the request. 

• A firmware cycle immediately following one in which a 
Megabus cycle was initiated and to which a response is 
expected. The clock remains stalled until the selected 
unit acknowledges or rejects the request. 

• A firmware step that calls for data from a bus buffer that 
has not yet been filled. The clock remains stalled until 
the applicable buffer is full. 

The clock is stalled by inhibiting the clock cycle generator 
(specifically MCLOCK pulses) when the CPU is initially powered- 
up, during a read or write cycle initiate, or for single-word or 
double-word data transfers from an external device (i.e., memory 
or I/O). The specific type of stall operation is determined by 
bits 31 through 35 of the control store word (BS Field). 

4.1.2.1 Read Cycle Initiate Stalls 

A Read Cycle Initiate is defined as a firmware step that re- 
quests data from a source external to the CPU (e.g., memory), and 
is intended to allow firmware to use the data in subsequent 
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firmware steps. The clock cycle generator is inhibited at the 
next MCLOCK pulse r preventing any further clock activity until 
the request is accepted or rejected over the Megabus. 

4.1.2.2 Write Initiate Stalls 

During a write operation to an external device, the clock is 
stalled until the device responds with a positive or negative 
acknowledgment . 

4.1.2.3 Data Stalls 

A Data Stall operation inhibits MCLOCK pulses to provide any 
additional time needed to fill the Data (BD) buffer or the Pro- 
cedure buffer with pertinent data from memory. Two basic signals 
are used for this purpose. The first, ALOUTD, denotes that the 
data buffer is empty; the second, ALOUTP, denotes that the pro- 
cedure buffers are empty. A third signal, PURGEF, inhibits addi- 
tional double-fetch operations until all previous double-fetch 
requests have been answered and discarded. 

4.1.3 Clock Cycle Generator 

The clock cycle generator provides the selectable clock 
pulses used throughout the CPU, and consists of three delay lines 
plus associated control logic. Delay lines 1 and 2 generate the 
primary Master Clock (MCLOCK) pulse; delay line 3 generates the 
two previously described secondary clock pulses (MLRVLD and 
MCDCNP) . All delay lines are tapped at selected intervals to 
generate their respective clock cycles. 

4. 2 CONTROL STORE 

Control within the CPU is provided by the generation of spe- 
cifically formatted 64-bit control words. Each word is selec- 
tively obtained from a 2,048 location Read Only Storage (ROS) 
memory, which is called the control store. The 64-bit output 
from the control store forms the input to the Control Store Local 
Register (CR) • Figure 4-2 illustrates the control store logic 
and includes the control store local register. 

4.2.1 Control Store Local Register (CR) 

The CR register retains firmware control words that emanate 
from control store for one complete firmware cycle (i.e., the 
control store output, or firmware word, is strobed into the local 
register at the positive transition of the clock input to the 
register, and it retains this data until new data is available at 
the positive transition of the next primary clock pulse). Out- 
puts from the CR register are available for distribution through- 
out the CPU. 
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STORE. INSTEAO, THE OUTPUTS FROM CONTROL STORE (SITS 23 
THROUGH M) ARE FED TO THE RALU ADDRESSING LOGIC TO 
PARTICIPATE IN GENERATING RAM/RAIU ADORESSES. 



Figure 4-2 Control Store Local Register 
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The Left and Right Select address bits (i.e., control store 
bits 1 through 3 and 5 through 7) are not stored directly into 
the local register. Instead, they are fed to the microprocessor 
(RALU) addressing logic where they are used in conjunction with 
the Select Modify bits (i.e., control store 
to generate the 4-bit left and right select 
the local register. These input signals to 
and their corresponding output signals are: 
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address inputs for 
the local register 
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4.2.2 Control Store Addressing 

Control store addressing is primarily controlled by the next 
address generation logic (refer to subsection 4.3) . 

4.3 NEXT ADDRESS GENERATION (NAG) LOGIC 

The NAG logic (see Figure 4-3) generates the next firmware 
address for the control store using one of three methods. All 
methods use bits 53 through 63 of the firmware word to form a 
tentative next address. These bits comprise the 11-bit NA field 
that can directly address any one of the 2,048 control store 
locations. 

Method 1 : This method uses as the alternate next address, 
bits 53 through 61 of the firmware word, in conjunction with log- 
ical Ones replacing bits 62 and 63, to form the 11-bit address. 

yet hod 2 : This method obtains the alternate next address 
from the CPU branch logic which generates numerous predefined 
addresses. The address generated is determined from a decode of 
the instruction register contents and other control logic. 
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Method 3 : This method uses the 8-bit contents of 
register with three constant bits {as shown below) to 
alternate 11-bit address. 
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The next address generation logic can be divided into four 
areas: (1) test logic, (2) branch logic, (3) LINK register, and 
(4) address generator. These logic areas and selected fields of 
the firmware word make possible the above methods of generating 
the next firmware address. 

4.3.1 Test Logic 

The test logic receives inputs from sources both internal and 
external to the CPU, providing 69 hardware signals that can be 
used as test conditions. One of the 69 test signals is selected 
by the TC Field of the current firmware word to participate in 
generating the next firmware address. These test conditions are 
too numerous to catalog here, but are defined in Table 3-16. 

The output from the test logic (hereafter referred to as the 
test signal) indicates whether or not the test condition is sat- 
isfied, and is fed directly to the address generator. The test 
signal is used by the address generator to determine whether to 
substitute the alternate next firmware address for the tentative 
value (CRNA01-11) . 

4.3.2 Branch Logic 

The branch logic contains several branch PROMs that provide 
the next firmware address for major branch operations. 

4.3.3 LINK Register (XL) 



The XL register is an 8-bit firmware address register (not 
visible to software) that supplies eight bits of the next firm- 
ware address when a Link Branch (or subroutine return) type op- 
eration is selected; the most significant two bits of the address 
are forced to 01 and the least significant bit is forced to Zero. 

4.3.4 Address Generator 

The address generator provides the next firmware address for 
the control store. The precise manner used to generate the next 
address is determined by the BR Field of the current firmware 
word. This field specifies the type of branch operation being 
performed as a result of a specific test condition. The eight 
branch types that can be specified include two binary branches 
(XO and XL) and six major branches (XA, XB, XR , XE , XW, and XF) . 
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4. 3. 4. 1 XC Branch 

The XO branch typt consists of both unconditional and condi- 
tional branches. The alternate next address is derived by per- 
forming a logical OH operation between the NA field and a value 

of 3 (hexadecimal) . 

4. 3.4.2 XL Branch 

The XL branch type returns control to the normal firmware se- 
quence after execution of a firmware subroutine. The alternate 
next address is determined from the contents of the LINK 
reg ister . 

4.3.4. 3 XA Branch 

The XA branch type is used as the first step in analyzing 
each instruction. Formation of the alternate next address for 
XA branches depends on the instruction form. 

4.3.4.4 XB Branch 

The XB branch type is used to analyze the address syllable 
portion of the data descriptor for commercial type instructions. 

4. 3.4.5 XR Branch 

The XR branch type is used to fetch an indirect address, per- 
form indexing, read operand(s) from memory, or execute jump type 
or I/O type instructions. 

4.3.4.6 XE Branch 

The XE branch type completes the op-code decoding necessary 
to begin execution of the single- and double-operand instructions 
included in the CPU instruction repertoire. 

4.3.4.7 XW Branch 

The XW branch is used to store a result. 

4. 3.4.8 XF Branch 

The XF branch type is used to exit the instruction currently 
being executed and return to the Instruction Fetch firmware. 

4 . 4 MICROPROCESSOR 

The microprocessor (see Figure 4-4), hereafter referred to as 
the Register File and Arithmetic Logic Unit (RALU), performs 
arithmetic, logical, and shift operations as directed by the 
current firmware word. 

The major logic areas of the RALU are: 
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• Microinstruction decoder 

• Register file 

• Q register 

• Data source selector 

• Ari thme tic/Logic Unit (ALU) 

• Data output selector 

• Shift logic. 

4.4.1 Microinstruction Decoder 

Control store generates a microprocessor instruction by en- 
coding the RALU input control lines (10 through 18) with the mi 
croinstruction code necessary to process data through the RALU. 
This is accomplished using the AD, AF, and AS fields of the cur 
rent firmware word as shown below: 



AD FIELD 



AF FIELD 



AS FIELD 



11 10 09 15 14 13 19 18 17 

i i \ i t t tit ' 




CONTROL STORE 
BITS 

RALU INPUT 
CONTROL LINES 
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FUNCTION 
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SOURCE 



4.4.2 Register File 

The Register File (RF) is the operand storage facility of the 
RALU, consisting of 16 registers; two working registers, seven 
data registers, and seven base registers. Each register is 20 
bits wide. 

The two working registers (DO and BO) are not software- 
visible, and provide a temporary storage facility when manipu- 
lating data during firmware operations. These registers are lo- 
cated in RF locations and 8, respectively. 



vis 
reg 



The seven data registers 
ible, representing software registers Rl thr 
isters are located in RF locations 1 through 



(Dl through D7) are software- 

isters Rl through R7. These 



7. 



The seven base registers (Bl through B7) are software- 
visible, and are located in RF locations 9 through F. 

Cf the 16 register file locations, any two can be simulta- 
neously accessed by the firmware, providing dual operands in a 
single firmware step. The contents of the selected locations 
(or location, if the addresses are the same) appear as the left 
and right outputs from the register file. The left output may 
be routed directly (via the data output selector) to the internal 
bus source selector, while both the left and right outputs are 
available as sources for the J and K ports. 
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Figure 4-4 Microprocessor Functional Overview 



4-11 



4.4.3 Q Registe r 

The Q register can function as a scratch pad or an extension 
of any register file register during shift operations and normal 
transfers of data. This allows, for example, the retention of 
the least significant half of a double-length product during a 
multiply operation. Although the Q register is 20 bits wide, 
only the least significant 16 bits are used during double- 
precision shift operations. 

4.4.4 Data Source Selector 

The data source selector is a steering device for data within 
the RALU, and consists of separate multiplexers for the J and K 
inputs to the ALU. The sources that serve as inputs to these 
multiplexers include: 

• Register file left and/or right output 

• register 

• Internal bus 

• Logical Zero, 

The J multiplexer can select any of the above, except the 
right register file output and the Q register, while the K multi- 
plexer can select any but the internal bus; logical Zero can be 
selected by either the J or K multiplexer but not both 
simultaneously. 

4.4.5 Arithmetic/Logic Unit (ALU) 

The ALU is the heart of the CPU, performing arithmetic, log- 
ical, and compare operations as directed by the firmware. The 
ALU has two inputs (J and K) that are sourced from the data 
source selector, and one 20-bit output that may be selected as 
an input to either the register file or the C register, and is 
made available to the internal bus source selector via the data 
output selector (AU) . 

The ALU can perform €4 arithmetic and logical operations as 
directed by RALU input control lines 10 through 15 (see Table 
4-1). These operations include the following features: 

• Full Carry Look-Ahead 

• Overflow Detection 

• Result Sign Detection 

• All Zeros Detection. 

Other ALU outputs that can be tested and/or copied by the 
firmware include: (1) overflow, (2) carry out, and (3) ALU out- 
put equals Zero. These three test signals can relate to an en- 
tire 20-bit operation or only the least significant 16 bits. 
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Table 4-1 RALU Logical and Arithmetic Operations (Sheet 1 of 2 
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DEFINITIONS 



X = don't care 
+ = addition 

- = subtraction 
& = logical AND 
V = logical OR 



V = exclusive OR 
D = ALU input from internal bus 
L = ALU input from L latches 
R = ALU input from R latches 
Q = ALU input from Q register 
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DEFINITIONS 



+ - 


addition 


D 


- = 


subtraction 


L 


& = 


logical AND 




V = 


logical OR 


R 


V = 


exclusive OR 


Q 



ALU input from internal bus 

ALU input from left output of register 

file 

ALU input from right output of register 

file 

ALU input from Q register 



4.4.5.1 Look -Ahead Logic 

The RALU consists of five stages, with each stage providing a 
Carry Generate and a Carry Propagate signal. These signals are 
used in conjunction with an external carry generator (i.e., ex- 
ternal to the RALU) to form the look-ahead logic. This logic de- 
termines whether or not the Carry Input (CN) to the RALU is prop- 
agated through each stage. The determination is based on an in- 
terpretation of the input operand rather than awaiting the ripple 
carry through each stage. 
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4. 4. 5.2 Overflow Logic 
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Under the preceding conditions, only a maximum value of +7 
and a minimum value of -8 is possible- Overflow is detected by 
comparing the carry-in and carry-out of the sign bit via an ex- 
clusive OR operation that is internal to the RALU; if the car- 
ries disagree, the overflow signal is not used during logical 
operations . 

4.4*5*3 Zero Detection Logic 

The Zero Detect outputs from the least significant four 
stages of the RALU are effectively tied together, enabling de- 
tection of a logical Zero condition for the 20-bit system. 

4.4.6 Data Output Selector 

The data output selector selects whether the left output from 
the register file or the ALU output is made available at the out- 
put (AU) of the RALU. This output can be used directly in the 
current firmware step, and is available to the internal bus 
source selector for distribution to other CPU elements via the 
internal bus. The output selector also specifies whether the ALU 
output is to be copied into the register file. If this is done, 
the register file location modified is the one that supplied the 
right output to the data input selector. 

NOTE 

Write operations can be performed only into the 
right side of the register file. 



4-15 



4.4.7 Shift Logic 

The RALU shift logic optionally shifts the output of the ALU 
(or the ALU and the register) before delivering the results to 
the register file (or the register file and the Q register). The 
shift logic is capable of shifting single- or double-word oper- 
ands left or right by one bit position as directed by RALU input 
control lines 16 through 18 (see Table 4-2) . 





Table 4- 


2 RALU Shift Op 


erat ions 


DESTINATION 


SHIFT OPERATIONS 


INSTRUCTION 


REGISTER FILE 


Q REGISTER 


MODIFIER BITS 


FUNCTION 


FUNCTION 


18 


17 


16 


SHIFT 


LOAD 


SHIFT 


LOAD 











X 


X 


None 


ALU 








1 


X 


X 


X 


X 





1 





None 


ALU 


X 


X 





1 


1 


None 


ALU 


X 


X 


1 








Left 


ALU 


Left 


Reg . 


1 





1 


Left 


ALU 


X 


X 


1 


1 





Right 


ALU 


Right 


Reg. 


1 


1 


1 


Right 


ALU 


X 


X 



X = don't care 

In shift operations, the bit shifted into the vacated bit po 
sition is designated as SHIN (shift input), and is controlled by 
three flip-flops: SHIN1, SHIN2, and MISC (refer to subsection 
4.8). The SHIN function is selected as follows; 



MISC 



SHIN1 



SHIN2 


















1 





1 








1 


1 


1 








1 





1 


1 


1 





1 


1 


1 



SHIN 



Internal Bus bit 10 

Internal Bus bit 10 

Zero 

register bit IF* 

XB register bit 1 

¥ register bit 7 

Zero 

Q register bit IF* 



*During shift right operations; otherwise 
undefined . 
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4.4.7.1 Single Left Shift 

Bits OD through IF o£ the ALU result are placded in bits DC 

through IE of the selected register file location; bit IF of the 

selected register file location receives a copy of Q register 
bit 10. 



OC OD 



IF 



ALU 
RESULT 



OC 



OF 10 11 



IF 



Q REGISTER 



oc 



— % 

IE IF 



REGISTER 

FILE 

LOCATION 



4.4,7.2 Double Left Shift 



Bits OD through IF of the ALU result are placed in bits OC 
through IE of the selected register file location; bit IF of the 
selected register file location receives a copy of register 
bit 10. Q register bits OD through IF are placed in Q register 
bits OC through IE; Q register bit IF receives a copy of the 
SHIN function. 



OC OD 



IP 



QC OD OF 10 11 



1F 



ALU 
RESULT 



z 



J 




OC 



Ifc IF 



oc 



ie ir 



REGISTER FILE 
LOCATION 



Q REGISTER 

(BEFORE) 



SHIN 

FUNCTIC 



Q REGISTER 
(AFTER* 



Conceptually, the rightmost 16 bits of the ALU result are 
concatenated with the rightmost 16 bits of the Q register and 
shifted left one bit position with the SHIN function shifted in 
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on the right. The result is placed in the rightmost bit posi- 
tions of the register file location and the Q register, 

respectively. 

4.4.7.3 Single Right Shift 

Bits 10 through IE of the ALU result are placed in bits 11 

through IF of the selected register file location; bit 10 of the 

selected register file location receives a copy of the SHIN func 

tion. Bits 0D through OF of the ALU result are placed in bits 
0C through 0E of the selected register file location; bit OF of 

the selected register file location receives a copy of the SHIN 
function . 



OC 00 OFilO 



1E 1F 



OC OE OF 10 11 



ALU RESULT 




( SHIN FUNCTION 



REGISTER FILE 
LOCATION 



Conceptually, the rightmost 16 bits of the ALU result are 
shifted right one bit position with the SHIN function shifted 
in on the left. The result is placed in the 16 rightmost bit 
positions of the register file location. 



4.4.7.4 Double Right Shift 



Bits 
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bits 11 
ister bi 
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of the s 
SHIN fun 
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e placed in Q register 
esult is placed in Q reg- 
e ALU result are placed in 
ster file location; bit OF 
receives a copy of the 
ugh OF are placed in Q 
the ALU result is placed 
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OC OD OF 10 



IE IF 



OC,QO ofiq 



IE IF 



ALU 

RESULT 



SHIM V 

FUNCTION ' 



REGISTER 

FILE 

LOCATION 




Q REGISTE 
(BEFORE) 



Q REGISTE 
<AFTER> 



Conceptually, the least significant 16 bits of the ALU result 
and the least significant 16 bits of the Q register are concat- 
enated, shifted right one bit position with the SHIN function 
filling the most significant bit, and the result placed in the 

least significant 16 bits of the register file location and the 
reg ister , respectively. 

4.5 RALU ADDRESSING 

The RALU addressing logic can select any one of the 16 reg- 
isters located within the register file as directed by the LS, 
RS, and SM fields of the current firmware word. Eight of these 

registers are directly addressable by the LS and RS fields when 
the SM field equals zero (see Tables 3-1 and 3-2). Each of the 
16 registers can be addressed by using the SM field to modify the 
LS or RS register address. 



The LS, RS, and SM fields are each configured as 
that are allocated within the control store as follows: 



3-bit codes 



• 


LS: 


bits 


• 


RS: 


bits 


• 


SM: 


bits 



1 through 3 
5 through 7 
28 through 30 

These 3-bit fields generate hexadecimal addresses that de- 
liver the contents of a selected register (or registers) to the 
left and/or right output of the register file. The register se 
lection performed by the above address fields is defined in 
Table 3-13. 

The LS field also provides addressing for the Random Access 
Memory (RAM) which is external to the RALU (refer to subsection 

4.9.1) . 



to 



Write operations into the register file can be performed only 
a register that is accessed by the right select address lines. 



The SM field selects data from one of two sources to modify 
the LS or RS address: 

1. The following F register fields (refer to subsection 
1.6.2) : 



F Register Format 
0123456789AB 



SEL Counter 
1 3 



* 



m 



e 


B 



2. One of the following three constants: 

• D: (1,1,0,1) 

• E: (1,1,1,0) 

• F: (1,1,1,1) 

These signals are ANDed with the applicable LS or RS field, 
providing the input signals to the local register for the left 
and right select addresses. 

3.6 INTERNAL BUS 

The internal bus (BIXXOC through BIXX1F) provides a 20-bit 
.nde data path that transfers data among elements of the CPU as 
directed by the BI Field of the current firmware word (see Tables 
5-9 through 3-11). The internal bus receives inputs (via the in- 
:ernal bus source selector) from 14 sources, and makes its data 
available to 12 destinations (see Figure 4-5). These sources 
ind destinations are: 

Internal Bus Sources 

1. Constant Generators 

2. Megabus Data Buffer (BD) 

3. Megabus Interrupt Register (RUP) 

4. Megabus Procedure 1 Buffer (BPl) or Procedure 2 
Buffer (BP2) 

5. Control Panel 

6. H Register 

7. Indicator Register (I) 

8. Status/Security Register (S) 



-on 



9, Program Counter (P) , or i 
Memory Address Register (Y) , or > 
MMU Output (Physical Address) ) 

10. RAM 

11. Hexadecimal Decoder 

12. Trap Status (2-word) 

13. Register File (left) Output, or 
ALU Output (AU) 

14. Bootload PROM. 

Internal Bus Destinations 

1. Program Counter (P) 

2. Memory Address Register (Y) 

3. Indicator Register (I) 



Via Address Bus (BA) 



4. RAM 



♦-Group 1 



♦^ Group 2 
^ Group 3 



G r o up 4 



5. LINK Register (XL) 

6. Instruction Register (F/SEL) 

7. Control Panel Display 

8. H Register 

9. Status/Security Register (S) 

10. Megabus Data Lines 

11. ALU Data Source Selector 

12. Miscellaneous Control Elements 
(Control Flip-Flops, MMU, Test 
Log ic , etc.) 

Firmware can select one element (or combinations of several 
elements) as an internal bus source, and deliver these data to 
one destination in each of the four groups listed above. The 
combinations of internal bus elements that are available as in- 
ternal bus sources are: 

1. Two copies of ALU output (bits OC through OF) and three 
interleaving 2eros 



2. Eight copies of H register (bit 18) and ALU output (bits 
18 through IF) 

3. H register (bits 1C through IF) and contents of Megabus 
data buffer . 

4. H register (bits 1C through IF) and contents of Megabus 
procedure buffer 

5. H register (bits 1C through IF) and control word from 
control panel 

6. H register (bits 10 through 17) right justified and sign 
extended to 16 bits. 

4.7 CPU REGISTERS 

The CPU registers, except those contained within the RALU, 
are described in the following subsections. 

4.7.1 Indicator Register (I) 

The CPU Indicators can be loaded using the firmware controls 
described in Table 3-11. 

4.7.1.1 Arithmetic Indicators 

Two indicators can be loaded with the results of arithmetic 
operations in the CPU; the Overflow (OV) indicator and the Carry 
(C) indicator. The available inputs to these indicators are: 

1. OV Indicator 

• OVFL (ALU overflow signal) 

• Result of exclusive OR operation between internal bus 
bits 10 and 11 

2. C Indicator 

• CRY (ALU carry signal) 

• Internal bus bit 10 

• Internal bus bit IF 

• Q register bit IF just prior to right shift in the 
current firmware step. 

4.7.1.2 Bit Test Indicator 

Inputs available to the bit test indicator are: 

• AUZERO (ALU zero detect signal) 

• Internal bus bit 10. 
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Figure 4-5 Internal Bus Sources and Destinations 
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4.7.1.3 Input/Output Indicator 

This indicator stores the results of the last I/O instruction 
performed by the CPU. This is accomplished by making the Megabus 
acknowledge signal available at the input to this indicator. If 
the I/O instruction is accepted, the indicator is set; otherwise, 
it is cleared. 

4.7.1.4 Comparison Indicators 

Three indicators store the results of the last compare opera- 
tion performed in the CPU; the Greater Than (G), Less Than (L) , 
and Unlike Signs (U) indicators. The inputs available to these 
indicators are: 

1. G Indicator 

• Internal bus bit 10 is zero and the ALU output (16 
bits) is not zero 

• Complement of the SIGN flip-flop 

2. L Indicator 

• Internal bus bit 10 

• ALU result bit 0C 

• SIGN flip-flop 

3. u indicator 

• Internal bus bit 10. 

4,7.2 LINK Register (XL) 

Refer to subsection 4,3*3 for a description of the XL 
register. 

4*7.3 Counter Type Registers 

Counter type registers are versatile in that they are al- 
ternately used as a 4-bit counter or as a 4-bit storage reg- 
ister within their respective circuit conf igurations. 

4.7.3.1 Counter Register (CTR) 

The CTR register (RCTROF through RCTR3F) counts the number 
af procedure words fetched during instruction execution, and in 
conjunction with the program counter allows the Trap Handler 
software to reconstruct the instruction word address in the event 
an exception condition is detected in the CPU. To accomplish 
this, firmware initializes the register to a count of 1. 
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4.7.3.2 Select Register (SEL) 

The SEL register {RSELOF through RSEL3F) generally holds the 
least significant hexadecimal digit of the current instruction. 
At times, it is used to count repetitive actions in Shift, Multi- 
ply, or Divide operations. Data are received over internal bus 
bits 1C through IF. When the SEL register is used as a counter, 
it is decremented and its contents tested for zero. 

4.7-3.3 Byte Indexing Register (XB) 

The XB register (RXBOFF through RXB3FF) stores bits shifted 
out of RALU data registers during half-word, digit, or bit index- 
ing operations. At the start of each instruction, it is cleared 
to zero. Its output is sent directly to a hexadecimal decoder, 
and is also available to the internal bus for trap reporting. 

4.7.4 Instruction Register (F) 

The F register (RFOOFF through RF08FF) accepts and stores the 
most significant three hexadecimal digits of instructions from 
memory for execution in the CPU. 

4.7.5 H Register 

The H register (RH10FF through RH1FFF) is configured into two 
8-bit segments that accept data directly from the internal bus. 
Its output is available to the internal bus source selector for 
delivery to the internal bus, but as its contents are deposited 
onto the bus, the least and most significant eight bits of the 
register are swapped. 

4.7.6 Status/Security Register (S) 

The S register (RS01FF, RS02FF, and RS10FF through RSI 5FF) 
retains the system status and security codes for use within the 
CPU. It is also used for comparing the priority level of an in- 
coming interrupt request with the current CPU operating priority 
level (refer to subsection 4.11.2). This compare activity is 
performed to deny acceptance of an incoming request when the re- 
quest level is equal to or lower than the current CPU priority 
level. The contents of this register are controlled entirely by 
firmware, except for the CPU channel number (bits 8 and 9) which 
are switch controlled. 

4.7.7 P Register (Program Counter) 

The P register (RP03CF through RP22CF) consists of five 4- 
bit counters capable of being preset that retain and increment 
the current instruction address originally obtained from the 
internal bus. 
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4. 7. ft Memory Address Register (Y) 

The Y register (RY03CF through RY22CF) provides operand ad- 
dresses (via the address bus) for memory or a peripheral device. 
Its architecture and functionality are basically the same as the 
P register (refer to subsection 4.7.7). Also included is a log- 
ical switching network which, under firmware control, generates 
a 16-bit address field by isolating the most significant byte 
(bits 3 through 6) from the 20-bit address. The 16- and 20-bit 
address fields are defined in Section I as the Short Address 
Form (SAF) and the Long Address Form (LAF) , respectively. 

4.7.9 Mega bus Registers 

The Megabus registers consist of three temporary storage 
buffers that receive procedure and data words (over the Megabus) 
from memory. Refer to subsection 4.10.6 for a description of 
these buffers. 

4.7.10 Interrupt Register 

Refer to subsection 4.11.3 for a description of the interrupt 
reg ister . 



4.7.11 



M 



Register 



The M register accepts pertinent RAM data (see Table 4-3) as 
the RAM is being updated, and since this data is not immediately 
available from the RAM, the M register delivers it to the test 
logic and next address generation logic for instantaneous action 
This data is obtained from several sources and loaded into the M 
register as directed by the GP Field of the current firmware 
word. These sources include: 

• Y register bit 15 

• F register bit OA 

• SEL register bits and 2 

• H register bits 1A and IB 

• ZERO flip-flop 

• AUZERO (ALU Zero Detect signal). 







Table 4-3 M Register Format 


BIT 


SIGNAL 


DESCRIPTION 





RMTRAC 


Trace Trap Enable 


1 


RMSCI1 


SI memory operand length is double-word 


2 


RMSCI2 


S2 memory operand length is double-word 


3 


RMSCI3 


S3 memory operand length is double-word 


4 


RMSQB6 


B6 is in Stack or Queue mode 


5 


RMS OB 7 


B7 is in Stack or Queue mode 


6 


GOTSPU 


SIP is part of the processor complex 


7 


GOTBPU 


CIP is part of the processor complex 
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4.8 CPU CONTROL FLIP-FLOPS 

The control flip-flops receive inputs from sources both in- 
ternal and external to the CPU, permitting modification of firm- 
ware actions based on the results of operations performed through 
the system. 

4,8.1 SIGN Flip-Flop 

The SIGN flip-flop provides temporary storage of control in- 
formation during instruction execution, and may be set from: 

Internal bus bit 
Internal bus bit 4 
Internal bus bit 19 
One 
Zero. 



be set from 



4.8.2 MISC Flip-Flop 

The MISC flip-flop provides temporary storage of control in- 
formation during instruction execution, and is one of the flip- 
flops used to select the SHIN function for RALU shift operations 
(refer to subsection 4.4.6). The MISC flip-flop may 

• Complement of internal bus bit 19 

• Internal bus bits 4 through 9 equal to Zero 

• CRY - ALU Carry signal 

• ACK - Megabus Acknowledge signal 

• PROV - MMU Protection Violation signal 

• Zero 
« One. 



4.8.3 SHIN1 Flip-Flop 

The SHIN1 flip-flop is primarily used to select the SH * N 
function for RALU shift operations (refer to subsection 4.4.6) 
and may be set from: 

• 1(B) - I register Bit Test indicator 

• Zero 

• One. 



4.8.4 SHIN2 Flip-Flop 

The SHIN2 flip-flop is primarily used to select the SHIN 
function for RALU shift operations (refer to subsection 4.4.6) r 
and may be set from: 



Complement 

Zero 

One. 



of SIGN flip-flop 
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4.8.5 ZERO Flip-Flop 

The Zero flip-flop is primarily used for temporary storage of 
an ALU Zero Result condition, and may be set from: 

• ALU Zero Detect signal 

• QLT active flip-flop from control panel - equals One only 
if the last CPU Quality Logic Test (QLT) failed 

• Zero 

• One . 

4 .8.6 WRAP Flip-Flop 

The WRAP flip-flop facilitates the checking of address- 
arithmetic firmware to detect attempts to exceed the 20-bit 
capacity of the address registers. If WRAP is On, any access to 
the Negabus (read request or write operation) will result in 
the transmission of an illegal address or I/O channel number. 
This action results in no response via the Megabus, which is in- 
terpreted as an "unavailable resource." The WRAP flip-flop may 
be set from the inequality of the ALU Carry signal (CRY) and 
the SIGN flip-flop. 

4.8.7 NEWXR Flip-Flop 

The NEWXR flip-flop distinguishes between reentrant invoca- 
tions of the XR "splatter" branch. This flop is set when the SEL 
register is loaded from the internal bus (e.g., during instruc- 
tion fetch operations); it is cleared when a branch is performed 
to XR, XE, XW, or XF , and when the WRAP flip-flop is set or 
cleared . 

4.8.8 ACK Flip-Flop 

The ACK flip-flop remembers whether the most recent Megabus 
action was accepted or rejected: if ACK is On, the action was 
accepted; if ACK is Off, the action was rejected. 

4.8.9 YELLOW and PARER Flip-Flops 

The YELLOW and PARER flip-flops signal detection of an error 
in memory or on the Megabus. YELLOW remembers whether at least 
one data error was corrected by the memory Error Detection And 
Correction (EDAC) hardware since the last interrogation of this 
flip-flop; YELLOW is cleared each time it is interrogated by the 
firmware. PARER remembers whether the most recent Megabus buffer 
reference (BD or BP) reported either a Megabus parity ^rror or a 
data error not correctable by memory EDAC hardware. Mless the 
control panel is in Load, Read, or Write mode, the setting of 
PARER forces the firmware to control store location 00 r for suit- 
able trap generation. 



4.8.10 EXTRAP, INTBSY, and TICK Plip-Flops 

The EXTRAP, INTBSY, and TICK service request flip-flops are 
set by hardware to signal a requirement for a break in firmware 
flow, 

EXTRAP is true when one or more external processors (CIP or 
SIP) has detected a trap condition. EXTRAP becomes false when 
all external processors with trap conditions have delivered their 
trap words . 

INTBSY is set when an external interrupt of high enough pri- 
ority is received and accepted by the hardware. No further in- 
terrupt, regardless of priority, can be accepted until firmware 
services buffer RUP, reloads the level field in the S register, 
and clears INTBSY. 

TICK is set every 8-1/3 milliseconds by a crystal-controlled 
oscillator, signaling the need for service of the YELLOW logic, 
the RTC and/or WDT, and the control panel. 

4.8.11 LOAD, TRAFFIC, and PANOK Flip-Flops 

These flip-flops communicate control information between 
frimware and the operator. 

The LOAD flip-flop can be set and cleared both by the opera- 
tor and by firmware. During system startup operations, LOAD is 
normally set by the operator and, when bootload action is com- 
pleted, cleared by firmware. Thereafter, this flip-flop usually 
remains OFF, but is sometimes set briefly by firmware as a means 
of preventing a trap to location 000 when a Megabus cycle is 
addressed to a possibly unavailable resource. 

The TRAFFIC flip-flop is loaded by firmware to control the 
corresponding indicator on the control panel, but is held OFF by 
hardware unless the control panel is in Run mode. The TRAFFIC 
flip-flop may be set from the complement of the ZERO flip-flop, 
which indicates whether or not the instruction op-code just 
fetched from memory is an HLT (Halt). 

The PANOK flip-flop synchronizes the servicing of operator 
requests. It is set to Zero whenever the CLEAR or EXECUTE push- 
button is depressed and when, in register-change mode, a hexa- 
decimal key is depressed. This flip-flop is set to One by the 
firmware that services the request, and is used to prevent multi- 
ple servicing of a single key-stroke. 

4.8.12 EFFRING, MONPROC f NOCHECK, SEGERR, and PROV C ontrols 

These signals and flip-flops support normal MMU operations, 
permit temporary alteration of access rules, and report errors 
detected by the MMU. 
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EFFRING is a two-bit register containing the effective ring 
number, which the MMU uses to determine the degree of privilege 
appropriate to the current instruction, and against which memory 
access requests arfe tested- Firmware loads EFFRING from the S 
register RING field at the start of each instruction. EFFRING 
is modified to decrease its privilege level whenever, in the 
course of formulating an address, it uses data that might have 
been generated by a less privileged program. 

NONPROC establishes a temporary change in the rules of ac- 
cess. Memory references which use the P register as the address 
source normally require "Execute" permission; when NONPROC has 
been set, they require only "Read" permission. 

NOCHEK establishes a temporary suspension of the rules of 
access (it does not affect the mapping of segmented virtual ad- 
dresses to physical, nor the detection of illegal, non-existent 
addresses). The intent of this functionality is to remove re- 
strictions on memory access by system firmware (interrupt and 
trap handlers, RTC/WDT service, panel routines, etc.). 

SEGERR signals that the MMU has detected an error in a vir- 
tual address; the referenced segment is not valid, or its size 
has been exceeded, or a protection violation has been detected. 
If SEGERR occurs during a memory reference, it causes the trans- 
mission of an illegal physical address. This action results in 
no response via the Megabus, which is interpreted as an unavail- 
able resource. If no memory reference or access-rights test is 
requested, signal SEGERR is ignored. 

PROV signals that the MMU has detected a protection violation 
(failure of access-rights check) on an otherwise legal address 
(i.e., an address in a valid segment and within the segment 
size). If a protection violation occurs during a memory refer- 
ence, the PROV flip-flop is locked in the set state until cleared 
by the firmware function NOCHEK (this function is normally issued 
by the trap-generation firmware). If a protection violation oc- 
curs during a firmware step that explicitly requests an access- 
rights test, the next firmware step may copy PROV to the MISC 
control f 1 ip-f lop. 

4.9 MISCELLANEOUS CPU HARDWARE 

The following subsections describe those CPU elements not 
previously defined under one of the major CPU logic areas. 

4.9.1 Random Access Memory (RAM) 

The RAM consists of sixteen 20-bit auxiliary storage regis- 
ters that the CPU uses as work areas, and to maintain selected 
system status conditions. Addressing the RAM for a red or write 
operation is performed by the Left Select portion of the RALU ad- 
dressing logic (refer to subsection 4.5). However, the actual 
RAM read or write operation is performed as directed by the DI 
Field of the current firmware word. 



The orqanization of the RAM is illustrated in Figure 4-6. 
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Figure 4-6 RAM Format 

4.9.1.1 RAM Location 

This RAM location contains the instruction word to be re 
ported when a trap occurs. 
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4,9,1.2 RAM Locations 1 through 3 

Bits OC through 17 of these RAM locations are unused; bits 18 
through IF contain software mode registers Ml through M3. 

4*9.1.3 RAM Location 4 

Bits 10 through 17 of this RAM location contain the mode in- 
formation for enabling the Real Time Clock (RTC); bits 18 through 
IF contain software mode register M4. 

4.9.1.4 RAM Location 5 

Bits OC through 17 of this RAM location are unused; bits 18 
through IF contain software mode register M5. 

4.9. 1. 5 RAM Location 6 

Bits 10 through 17 of this RAM location contain the mode in- 
formation for enabling the Watch Dog Timer (WDT) ; bits 18 through 
IF contain software mode register M6. 

4.9.1.6 RAM Location 7 

Bits OC through 17 of this RAM location are unused; bits 18 
through IF contain software mode register M7. 

4.9.1.7 RAM Location 8 

This RAM location contains a pointer to the next word of 
proced ure. 

4.9.1.8 RAM Location 9 

This RAM location is unused. 

4.9.1.9 RAM Location A 

This RAM location contains a stack pointer. 

4.9. 1.10 RAM Location B 

This RAM location contains the Remote Descriptor Base (RDB) 
register . 

4.9.1.11 RAM Location C 

This RAM location contains a pointer to the most recently 
accepted Commercial Instruction Processor (CIP) instruction. 

4.9.1.12 RAM Location D 

This RAM location contains a pointer to the most recently ac- 
cepted Scientific Instruction Processor (SIP) instruction. 
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4.9.1.13 RAM Location E 

This RAM location is unused. 

4.9.1.14 RAM Location F 

This RAM location contains a pointer to the next word of 
procedure. 

4.9.2 Bootload PROM 

The bootload PROM, which consists of four 2K PROMs r is a 
standard feature of the CPU. Addressing for the boot PROM is 
provided by bits 14 through 22 of the address bus. The 20-bit 
output from the boot PROM is delivered to the internal bus 
either as directed by the BS Field of the current firmware word 
or when the Load pushbutton on the control panel is depressed. 

The bootload operation has the following modes of operation, 
depending on the contents of the program counter (P) : 



P CONTENTS 


OPERATION 


0000 


Executes Basic Logic Test (BLT) . 




Reads one physical record from channel 010 (hexa- 




decimal) into memory, starting at location 0100 




(hexadecimal); branches to 0100 (hexadecimal). 




The preceding is the default Bootload procedure.* 


0002 


Does not execute BLT. 




Reads one physical record into memory, starting at 




location 0100 (hexadecimal), using the channel 




number previously entered into register Dl; 




branches to 0100 (hexadecimal) • 


0004 


Does not execute BLT. 




Reads one physical record into memory, starting at 




the address entered into register Bl, using the 




channel number entered into register Dl; branches 




to the address entered into register Bl. 



*This procedure is used when the control panel is locked. If 
the control panel is unlocked, procedure will halt after the 
BLT unless Run (R) pushbutton is depressed. 



as 



The devices 
follows : 



supported and the Boot record file formats are 
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DEVICES 



Diskette 



Card 



Paper Tape 
(ASK) 



Cartr idge 

Magnetic 
Tape 



RECORD FORMAT 



Data portion (128 bytes) of track 0, sector 
(first sector) 

The contents of the first card; 80 bytes punches 
in Bootload format 

One record of 256 bytes or less, starting with the 
character that follows the first non-NUL character 
and continuing to the first X-OFF or T-OFF character 
with no escaped data 

Data portion (256 bytes) of track 0, sector 

One record of 256 bytes or less; the record must be 
the first after BOT 



4.9.3 Address Bus 

The address bus (MYAD03 through MYAD22) accepts addresses 
from the P and V registers (refer to subsections 4.7.7 and 4.7.8, 
respectively) as directed by the BS Field of the current firmware 
word. The 20-bit output from the address bus is delivered to the 
Megabus for I/O and memory read or write operations, or to the 
internal bus for distribution in the CPU. 

4.9.4 Memory Management Unit (MMU ) 

The MMU checks all memory addresses before permitting them to 
take part in a memory reference (either over the Megabus to main 
memory or to the cache memory) . These checks ensure that ad- 
dresses are legitimate and do not violate any software imposed 
restrictions. If a memory address is rejected by the MMU, a pro- 
tection violation results. Addresses before being processed by 
the MMU are called Virtaul addresses, while addresses after being 
processed by the MMU are called Physical addresses. 

4.9.5 Cache Memory 



The cache memory conta 
enced) main memory locatio 
allows it to make main mem 
CPU and to monitor the Meg 
it currently contains a co 
dressed. The cache also h 
communicate to the CPU to 
main memory read requests 
committed to locate the da 
or in the actual main memo 
is returned to the CPU wit 



ins copies of selected 
ns. It has a Megabus i 
ory read references on 
abus , copying main memo 
py of the main memory 1 
as a private interface 
which it is dedicated* 
across this interface , 
ta for the CPU in its 1 
ry. In either case, th 
h an appropriate handsh 



( recently ref er- 
nterf ace which 
behalf of the 
ry wri te data i f 
oca t ion ad- 
allowing it to 

It receives 
thereby becoming 
ocal cache array 
e requested data 
ake . 
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4.9.6 Hexadecimal Decod er 

The hexadecimal decoder (RXBD10 through RXBD1F) generates 16- 
bit masks for bit test operations {i.e., a single bit within a 
16-bit word can be selected). The bit being tested is selected 
by the 4-bit value from the XB register (refer to subsection 
4.7.3.3). This value is used to define which of the 16 bits is 
zero; the other 15 bits are made all ones. 

4.9.7 Subcommand Generator 

The 6-bit GP field of the Control Store Word (CSWD) is es- 
sentially viewed by firmware as three independent hexadecimal 
subfields: 10, 20, and 30 r which control various hardware opera- 
tions. Actually, these subfields provide a 6-bit hexadecimal ad- 
dress {0 through 3F) to two PROM devices and a binary-to-decimal 
decoder. These devices comprise the subcommand generator (see 
Figure 4-7) which provides control signals (subcommands) for the 
CPU hardware. 

Decoder selection occurs when CSWD 36 through 38 equal 6 
(110 ) and NCLOCK+ is inactive. This disables the two PROMs and 
enables the least significant three bits of the low-order address 
field (CSWD 39 through CSWD 41) into decoder 30 for selection of 
the applicable control signal. Also, when CSWD 36 and 37 equal 
3 (11 ), they enable the control panel for service by the CPU. 

Selection between the two PROMs is performed by CSWD 36 and 
37 as indicated below: 



CSWD 


PROM 


36 


37 






1 




1 



10/20 
10 
20 



This enables the respective hexadecimal address field into 
the selected PROM for selection of the applicable control 
signal (s) - 

MOTE 

Some overlap between the two PROMs can oc- 
cur to provide adequate control signal 
selection . 
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Figure 4-7 Subcommand Generator Logic 
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4.9 .8 Constant Generators 

The CPU constant generators provide two types of constants, 
which are available as internal bus sources as directed by the 
BT Field of the current firmware word. These constants are: 

1. Numeric constants, and 

2. Constants used to generate control words for communica- 
tion with external processors, 

4.9.9 Control Panel 

Refer to subsection 4.12 for a description of the full con- 
trol panel. 

4.10 MEGABUS NETWORK 

The Megabus provides a common communication path among avail- 
able system units. The design of the Megabus is asynchronous to 
make communications possible between units of varying speeds. 

4.10.1 Interface Logic 

The Megabus interfaces with the CPU via a group of tran- 
sceivers that provide the equivalent electrical characteristics 
required of all bus connections to allow data, address, and con- 
trol signals to be routed to and from the CPU. Table 4-4 pro- 
vides a complete list of the interface signals, while subsections 
4.10.1.1 through 4.10.1.6 provide a brief description of each 
Megabus/ CPU interface signal. 

4-10.1.1 Timing Signal Lines 

The following signals provide the handshake function required 
by a unit to either initiate, accept, or deny a request for a 
Megabus cycle from another unit. 

Bus Request (BSREQT-) 

When true, this signal indicates that one or more of the 
units connected to the Megabus have requested a bus cycle. When 
the signal is false, no requests are pending. 

Bus Data Cycle Now (BSDCNN-) 

When true, this signal indicates that a specific master unit 
has been granted a requested Megabus cycle and has placed infor- 
mation on the bus for use by a specific slave unit. When this 
signal is false, the bus is not busy (i.e., between bus cycles). 
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Table 


4-4 Megabus Interface S 
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(Sheet 


1 of 2) 








CPU SIGNAL 


DRIVER 


DRIVER 


RECEIVER 


BUS 


TYPE 


FUNCTION 


ENABLE 


INPUT 


OUTPUT 


SIGNAL 


Bus 


Bus Request 


GROUND 


MYREQT+ 


BSREyT-*- 


BSREQT- 


Handshake 


Data Cycle Now 


GROUND 


MYDCNN+ 


BSDCNN-t- 


BSDCNN- 




Acknowledge 


GROUND 


KYACKR4 


BSACKR4 


BSACKR- 




Negative Acknowledge 


GROUND 


MYNAKR4 


BSNAKR4 


BSNAKR- 




Wait 


GROUND 


GROUND 


BSWAIT+ 


BSWA3T- 


Data 


Data Bit A (unused) 


- 


- 


- 


BSDT0A- 




Data Bit 


MYDCNW- 


Brxxio-t- 


BSDT00+ 


BSDT0O- 




Data Bit 1 


MYDCNW- 


BIXX11+ 


BSDTQ1+ 


BSDT01- 




Data Bit 2 


NYDCNW- 


BIXX12+ 


BSDT02+ 


BSDT02- 




Data Bit 3 


HYDCNW- 


BIXX13+ 


BSDT03+ 


3SDT0 3- 




Data Bit 4 


MYDCNW- 


BIXX14.+ 


BSDTQ4+ 


BSDT04- 




Data Bit 5 


MYDCNW- 


BIXX154 


BSDT05+ 


BEDT05- 




Data Bit 6 


MYDCNW- 


BIXX16+ 


BSDT06+ 


BSDT06- 




Data Bit 7 


MYDCMN- 


MYDT17+ 


BSDT07-- 


BSDT07- 




Data Bit B (unused) 


- 


- 


- 


BSDTOB- 




Data Bit 8 


MYDCHN- 


MYDT18+ 


BSDT08+ 


BSDT08- 




Data Bit 9 


MYDCNN- 


MYDT194 


BSDT09+ 


BSDT09- 




Data Bit 10 


MYDCNN- 


*1YDT1A4 


BSDT10+ 


BSDT10- 




Data Bit 11 


MYDCMW- 


8IXX1B+ 


BSDT114 


BSDT11- 




Data Bit 12 


MYDCMW- 


BIXX1C4 


BSDT124 


BSDT12- 




Data Bit 13 


MYDCNW- 


BIXX1D4 


BSDT13+ 


BSDT13- 




Data Bit 14 


MYDCNW- 


3IXX1B4 


BSDT14+ 


BSDT14- 




Data Bit 15 


MYDCNW- 


3IXX1F4 


BSDT15+ 


BSDT15- 


Main 


Address Bit 


MYDCNN- 


GJAD0 0+ 


BSAD00+ 


BSADO0- 


Memory 


Address Bit 1 


MYDCNN- 


ZGNDAA 


BSAD01+ 


BSAD01- 


Address 


Address Bit 2 


my:x:nn- 


ZGNDAA 


BSAD02+ 


B5ADD2- 




Address Bit 3 


MYDCNN- 


GJAD03+ 


BSAD03+ 


BSAD03- 




Address Bit 4 


MYDCNN- 


G J ADO 4+ 


BSAD04+ 


BSADC4- 




Address Bi t 5 


MYDCNN- 


GJAD0 5+ 


BSAD0 54 


BSAD0 5- 




Address Bit 6 


MYDCNN- 


GJAD06+ 


BSAD064 


BSAD06- 




Address Bit 7 


MYDCNN- 


GJAD07+ 


BSAD07+ 


BSAD07- 




Address Bit 8 


MYDCNN- 


GJAD08+ 


BSAD034 


BSAD08- 




Address Bit 9 


MYDCNN- 


GJAD09+ 


BSAD094 


BSAD09- 




Address Bit 10 


MYDCNN- 


GJAC10+ 


BSAD104 


BSAD10- 




Address Bit 11 


MYDCNN- 


GJAD11+ 


BSAD114 


BSAD11- 




Address Bit 12 


MYDCNN- 


GJAD12+ 


BSAD12+ 


BSAD12- 




Address Bit 13 


MYDCNM- 


GJAD134 


BSAD134 


BSAD13- 




Address Bit 14 


MYDCNM- 


GJAD14+ 


BSAD144 


BSAD14- 




Address Bit 15 


MYDCNN- 


MYAD15+ 


3SAD154 


BSAD15- 




Address Bit 16 


MYDCNN- 


MYAD16+ 


BSAD164 


BSAD16- 




Address Bit 17 


MYDCNN- 


MYAD174 


BSAD174 


BSAD17- 




Address Bit 18 


MYDCNN- 


MYAD18+ 


BSAD184 


BSAD18- 




Address Bit 19 


MYDCNN- 


MYAD19 + 


BSAD194 


BSAD19- 




Address Bit 20 


MYDCNN- 


MYAD20+ 


BSAD2 04 


BSAD20- 




Address Bit 21 


MYDCNN- 


MYAD2H- 


BSAD214 


BSAD21- 




Address Bit 22 


MYDCNN- 


MYAD22 4 


3SAD22+ 


BSAD22- 




Address Bit 23 


MYDCNN- 


RXBOFF* 


BSAD23+ 


BSAD23 


Transfer 


Memory Reference 


MYDCNN- 


CIMREF+ 


3SMREF4 


BSMREF- 




Byte 


MYDCNN- 


CRCLK0+ 


BSBYTE4 


BSBYTE- 




Bus Write 


MYDCNN- 


CIREAD 


BSWRIT+ 


BSWRIT- 




Second Half Read 


MYDCNN- 


NYSHBC+ 


BSSHBC+ 


BSSHBC- 




Locfc 


MYDCNN- 


MYRMWC* 


BSL0CK4 


BSLOCK- 




Memory Error (Red) 


MYDCNN- 


GROUND 


BSREDD4 


BSREDD- 




Menory Error (Yellow) 


MYDCNN- 


GROUND 


BSYELO+ 


BSYELO- 




Data Parity Left 


MYDCNN- 


MYDPOO+ 


BSDPOO+ 


BSDPOO- 




I>ata Parity Right 


MYDCNN- 


MYDP08+ 


B3DP084 


BSDP08- 




Address Parity (bits 0-7) 


MYDCNN- 


MYAP00+ 


BSAP004 


BSAP00- 




Double Full 


MYDCNN- 


XTDBPL+ 


B5DBPL+ 


BSDBPL- 



4-3R 
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CPU SIGNAL 


DRIVER 


DRIVER 


RECEIVER 


BUG 


TYPE 


FUNCTION 


ENABLE 


TMPUT 


OUTPUT 


SIGNAL 


Ver i fy 


Logic Test Out 




_ 


_ 


BSQLTO- 


Bus 


Logic Test In 


- 


- 


- 


BSQLTI- 


Continuity 


Logic Test Active 


- 


- 


- 


BSOLTA+ 


Establ ish 


Ti e-Breakinq Network 


_ 


_ 


— 


BSAUOK+ 


Positional 


Tie-Breaking Network 


- 


- 


- 


B55U3K + 


Priority 


Tie-Breakina Network 


- 


- 


- 


BSCUOK+ 




Tie-Breaki ng Network 


- 


- 


- 


BSDUOK4- 




Tie-Breaking Network 


- 


- 


- 


BSEUOK4- 




Tie-Breaki ng Network 


- 


- 


- 


BSFUOKt 




Tie-Breaking Network 


- 


- 


- 


BSGUOK+- 




Tie-Breaki ng Network 


- 


- 


- 


BSHUOK+ 




Ti e-Breakinq Network 


- 


- 


- 


BSIUOK-*- 




Tie-Breaki ng Network 


- 


- 


— 


BSMYOK+ 


Misce] laneous 


Master Clear 


GROUND 


MYMCLP + 


BSMCLR+ 


BSMCLR- 




Power On 


- 


- 


- 


BSPW0N + 




Resume Interrupt 


GROUND 


ENRIMT+ 


BSRINT+ 


BSRINT- 




Spare Line (unused) 


- 


- 


- 


BSSPR1- 




Spare Line (unused) 


- 


- 


- 


BSSPR3- 




Spare Line (unused) 


- 


- 




BSSPR4- 




External Connection (unused) 


- 


- 


— 


BSEXTC+ 



Bus Acknowledge Response (BSACKR-) 

When true, this signal indicates to the master unit that the 
slave unit has received and accepted a specific transfer from the 
master unit. 

Bus Negative Acknowledge Response (B5NAKR-) 

When true r this signal indicates to the master unit that a 
slave unit is refusing a specific transfer (i.e*, the slave unit 
cannot accept the transfer and the master unit should not attempt 
a retry). For example, a busy memory addressed for a data 
transfer. 



If a situation arises when no unit on the bus recognizes the 
transfer because of improper addressing or a malfunction, and no 
response (ACK, NAK, or WAIT) is generated within 5 microseconds, 
the CPU (which monitors all bus transfers) will issue a Bus Neg- 
ative Acknowledge Response (BSNAKR-) signal on behalf of the en- 
tire system. This is referred to as the Dead Man Time-Out 
operation . 

Bus Wait (BSWAIT-) 



When true, this signal indicates to the master unit that the 
slave unit cannot accept a specific transfer at this time fi»e, 
the slave unit is temporarily busy and the master unit must in- 
itiate successive retries until the transfer is acknowledged). 
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4 . 10. 1.2 Information Signal Lines 

The signals described in this subsection effect the transfer 
of information during a bus cycle as data or information signals. 

Bus Data Lines (BSDT00- through BSDT15-) 

The bus data bits can be formatted for a single data word 
(16 bits), channel number coding (CPU) f or the low-order address 
bits (8 through 23), depending on the operation being performed. 
Thus, data, address, control, register, or status information can 
be reflected by the 16 data lines. 

Bus Address Lines (BSAD00- thorugh BSAD23-) 

The 24 address lines can be formatted for a single 23-bit 
main memory address to select one of 8M bytes. 

The address lines can also be formatted for a channel number 
code (CPU), and I/O function code on lines 18 through 23, or a 
combination of all three for an IOLD operation. 

4.10.1.3 Information Control Signal Lines 

The following signals serve as data, address, and information 
control signals that effect the transfer and control of such in- 
formation during a bus cycle. 

Bus Memory Reference (BSMREF-) 

When true, this signal indicates that bus address lines 
through 23 contain a complete main memory address from the master 
unit. When false, the Bus Memory Reference signal indicates that 
the bus address lines contain a channel number on lines 8 through 
18 (with or without a function code on lines 18 through 23), or a 
main memory module address code on lines through 7; the exact 
configuration and direction fo flow depends on the operation 
being performed. 

Bus Byte (BSBYTE-) 

When true, this signal indicates that the current transfer is 
a byte rather than a word transfer (used during memory write 
operations only) . 

Bus Write (BBWRIT-) 

When true, this signal indicates that the master unit is 
transmitting data to the slave unit. When thi s sign al is false, 
the initial bus cycle signals a read request (BSWRIT), while the 
data lines contain the requesting channel number; the slave unit, 
if it accepts the request, replies with a read response via a 
subsequent bus cycle, which is defined as a Second Half Bus Cycle 
(3SSHBC) . 

11/79 
4-4 FN28A 



3us Second Half Pus Cycle (RSSHRC-) 

Whentrue, this signal indicates to the master unit that the 
current information generated by the slave unit is the informa- 
tion previously requested during the initiation cycle. 

Bus Lock (BSLQCK-) 

When true, this signal indicates that the master has 
requested a change in the status of the memory unit lock flop. 
The bus lock signal also enables a three-cycle, Read-Modify- 
Write operation, which allows the following three cycles to be 
executed for the requesting unit without interruption (i.e., 
other units attempting a Read-Mod ify-Write operation will not be 
acknowledged) : 

1. First Cycle (read): The address bus contains the memory 
address, and the data bus contains the channel number of 
the requestor . 

2. Second Cycle (response): The address bus contains the 
channel number of the requestor, and the data bus con- 
tains data read from main memory. 

3. Third Cycle (write): The address bus contains the memory 
address, and the data bus contains data to be written 
into memory. 
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Bus Double Pull (BSDBPL-) 

When true, this signal indicates that the master unit is re- 
questing a double-word operand from the slave unit. During the 
first Second Half Bus Cycle, BSDBPL- is redelivered to the re- 
questing unit, indicating that another word follows. 

NOTE 

If a single fetch memory is installed on the 
system, BSDBPL- is not redelivered during the 
Second Half Bus Cycle, notifying the request- 
ing unit that only single-word operations will 
be performed - 

4. 10. 1. 4 Status/Error Signal Lines 

The following signal lines provide main memory error report- 
ing signals for the available units, and two-way bus parity lines 
for odd parity signals used with the address and/or information 
bits placed on the Megabus. Two lines provide for a bus contin- 
uity check, combined with a check on the integrity of the resi- 
dent logic test in each unit. A single line is used to indicate 
the status of system power. 

Bus Red (BSREDD-) 

The Bus Red error signal can only be generated by a main 
memory unit that contains EDAC logic. When true, the signal 
indicates that the memory has detected an error during a read 
(Second Half Bus Cycle) operation. 

Bus Yellow (BSYELO-) 



The Bus Yellow error signal can only be generated by a main 
memory unit that contains EDAC logic. When true, the signal in- 
dicates that memory has detected and corrected an error during a 
read (Second Half Bus Cycle) operation. 

Bus Address Parity (BSAP00-) 

The level of the Bus Address Parity signal provides odd par- 
ity for address bits through 7 (module address bits). 

Bus Data Parity - Left Byte (BSDP00-) 

The level of the Bus Data Parity - Left Byte signal provides 
odd parity for the left data byte (bits through 7) . 

Bus Data Parity - Right Byte (BSDP08-) 

The level of the Bus Data Parity - Right Byte signal provides 
odd parity for the right data byte (bits 8 through 15). 
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Bus Quality Logic Test Out (BSQLTO-) and In (BSQLTI-) 

The Bus Quality Logic Test Out and In signals are static in- 
tegrity signals which, if continuously true, indicate that each 
available unit performed its resident Quality Logic Test (QLT) 
successfully. The signal is relayed frorr unit to unit from one 
end of the bus to the other and back. This signal effectively 
provides a continuity check for all available units. 

Bus Quality Logic Test Active (B5QLTA+) 

When true, this signal indicates that at least one unit on 
the bus has not successfully completed its logic test or that 
there is a break in continuity on the bus (i.e., a unit is not 
instal led) . 

Bus Power On (BSPWON+ ) 

When the Bus Power On signal is true, it indicates that all 
system power supplies are functioning correctly. This signal 
goes true when power has stabilized and goes false several milli- 
seconds before power fails. 



4.10.1.5 Tie-Breaking Control Signals 



There are nine tie-breaking signals (BSAU0K+ through 
BSIUOK+) , all of which must be true to provide an enable for any 
unit requesting a bus cycle. If more than one unit simulta- 
neously requests a bus cycle, the cycle is granted to only one 
unit on a positional priority basis. The priority extremes are 
the ends of the bus; memory has the highest positional priority 
and the CPU has the lowest. Thus, under simultaneous request 
conditions, the highest positioned requesting unit receives true 
enables from all nine tie-breaking signals, while the remaining 
requesting units receive eight or less, depending on the relative 
position of their decreasing priority. 

Bus My OK (BSMYQK+) 

When true, this signal indicates to the next lower priority 
unit that the generating unit, and certain other units of a 
higher positional priority, have not requested a bus cycle within 
the last 20 nanoseconds; therefore, a cycle can be granted (if 
requested) to a lower priority unit. 

4.10.1.6 Operational Control Signals 

The following control signals are asynchronous in relation to 
the functions they perform and the normal initiation and control 
of bus cycles. 

Bus Resume Interrupt (BSRINT-) 

When true, this signal allows the CPU or memory to reissue an 
interrupt that has previously been refused. 
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Bus Master Clear (BSMCLR- 



When true, this signal indicates that the Master Clear (CLR) 
pushbutton, located on the CPU control panel, has been depressed. 

4.10.2 Megabus Network Operation 

The information contained in this subsection describes the 
bus cycle timing and controls in relation to the handshaking 
techniques used to establish communications between any two units 
in the system. Bus dialogue is completely asynchronous, and each 
bus cycle can be considered as an independent handshaking se- 
quence between a master unit and a slave unit. To implement this 
type of operation, all major logic boards within the units that 
comprise the system have similar Megabus cycle control logic. 

Figure 4-8 depicts the general timing relationships incurred 
when handshaking techniques are applied between a master unit and 
a slave unit on request of the master unit. The Bus Cycle Re- 
quest (BSREQT) signal is common to all available units, and when 
true, indicates that one or more have initiated a request for a 
bus cycle. 




bus and the CPU resides at the low priority end; the remaining 
units occupy intermediate priority positions. 

When a bus cycle is granted, the Bus Data Cycle Now (BSDCNN) 
signal goes true, indicating that the tie-breaking operation is 
complete and a specific unit has been granted master status 
(gained bus control). At this time, the data and address infor- 
mation designated for the slave unit is placed on the bus. As- 
suming a multi-unit system, the Bus Data Cycle Now signal allows 
each potential slave unit to internally generate a Data Cycle Now 
Delayed (BSDCND) signal. The delay (60 nanoseconds) provides bus 
skew correction time for each unit, allowing the currently active 
bus address information to be properly examined by the decoding 
networks available in each unit. Under these conditions, the 
Data Cycle Now Delayed signal, in conjunction with signal MYCHAN 
that is derived from the appropriate unit's decoding of the pre- 
defined address, allows an internal strobe to be generated in the 
designated slave unit. The slave unit then returns one of three 
response signals (BSACKR, BSNAKR, or BSWAIT) to the master unit 
to complete the handshake and to indicate that the slave unit 
acknowledges the communication as being accepted, denied, or 
postponed , respectively. 

A bus handshake is an asynchronous operation in which the 
change of a signal level can only occur in response to the level 
change of a handshake signal from a defined unit. Since various 
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units can differ in the length of time required between strobe 
development and acknowledgment, signal transitions depend on the 
type of internal functionality. In the case where no acknowledg- 
ment is received by a Master Unit (no response signal generated), 
the CPU Dead Man Time-Out operation allows a delay of 5- 
microseconds before clearing the bus on behalf of the entire 
system. 
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Figure 4-8 Bus Timing Diagram 
4,10,3 Megabus Tie-Breaking Function 

The tie-breaking function resolves simultaneous Megabus re- 
quests and grants bus cycles on a positional priority basis. In 
any given system, memory has the highest priority and the CPU has 
the lowest priority; they reside at opposite ends of the bus. 
Other units occupy intermediate positions and have a priority 
that increases relative to their proximity to the memory end of 
the bus. 

Each unit on the Megabus contains the logic necessary for 
granting a Megabus cycle. When the Data Cycle Now signal is 
valid, the requesting unit gains access to the Megabus. 
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Referring to Figu; e 4-9, note that each unit's grant logic mon- 
itors the preceding unit's tie-breaking lines (BSAUOK through 
(BSIUOK) . Therefore, only one unit has its grant logic satis- 
fied at any one time. The one primary line that is necessary to 
satisfy the input structure of the grant logic is BSAUOK. In 
reality, BSAUOK is the preceding higher priority signal BSMYOK. 

NOTE 

Main memory always takes priority on Megabus accesses 
and does not need to monitor the remaining unit's tie- 

breakinq lines. 
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Figure 4-9 Megabus Tie-Breaking Logic 

If the CPU requires access to the Megabus (as indicated by 
control store bit 31), the User flip-flop sets, initiating a CPU 
start request. When there is no Megabus activity, the Request 
flip-flop sets, producing a CPU bus request and disabling other 
units from gaining access to the Megabus during the processor re 
sponse (see Figure 4-10). 

With the Grant flip-flop set, the Data Cycle Now signal gen- 
erates one of the following three responses: Acknowledge (ACK) , 
Negative Acknowledge (NAK) , or Wait (WAIT). When the response 
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signal is received, the Grant flip-flop clears and the Megabus 
is available for use by another unit. 

4,10.4 Memory Read Request 

The CPU can: (1) with a single memory read request, signal 
that it wants the delivery of two sequential words from memory, 
and (2) have both a double-word and a single-word request out- 
standing to two different memory modules simultaneously. 

Double-word data is always stored in the PI and P2 Procedure 
Buffers whereas single-word data is stored in the Data Buffer 
(BD) . Since both single- and double-word requests may be present 
at the same time, the processor tags the request in the function 
code field at the time of the request* Single-word requests are 
tagged 00 16 , while double-word requests are tagged 20 76 . During 
the request, bus data lines 10 through 15 constitute the tag. 
During the Second Half Bus Cycle (BSSHBC) , address bits 18 
through 23 constitute the tag echoed by the memory. 

4.10.4.1 Double-Word Fetch 

A double-word fetch operation is executed only if: (1) the 
Procedure Buffers are both empty and (2) memory is not currently 
processing a double-word pull. Firmware then performs a Proce- 
dure Stall (setting the Procedure Buffer Stall flip-flop) until 
memory transfers either a procedure or the first word of a 
double-word fetch (see Figure 4-10). 

During the double word fetch operation, two flip-flops (Word 
A Request and Word B Request) sample the Second Half Bus Cycle 
signal. These two flip-flops set when a memory request is pre- 
sent and test the Second Half Bus Cycle signal when the CPU ack- 
nowledges with the My Second Half Response signal. When a double 
word is received from memory, the Word A Request and Word B Re- 
quest flip-flops are respectively cleared. During a single word 
fetch, only one Second Half Bus Cycle signal is received, clear- 
ing the Word B Request flip-flop. Two additional flip-flops. 
Take Word C and Take Word D, track the firmware's usage of the 
data received from memory. The Take Word C flip-flop clears when 
firmware uses the first word and the Take Word D flip-flop clears 
when firmware uses the second word from memory. 

4.10.4.2 Single Word Fetch 

Single word fetches require at least two firmware steps. The 
first step generates a Megabus Read Cycle causing the Data Buffer 
Stall flip-flop to be set when memory (or the I/O) accepts the 
request cycle. The second step attempts to input the data onto 
the internal bus. These two firmware steps need not be contig- 
uous. If the Second Half Bus Cycle signal is delayed, the Data 
Buffer Stall flip-flop remains set until the Second Half Read 
Data signal is received. 
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Figure 4-10 Megabus Control and Memory Read Request Logic 
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4.10.5 Response Summation 

The functionality of the CPU logic shown in Figure 4-10 is 
similar to that of all units operating as a slave unit. However, 
the specific logic used for the generation of the three response 
conditions (ACK, NAK, and WAIT) depends on the design require- 
ments of each individual unit. The following information sum- 
marizes slave unit response conditions. 

Acknowledge Response (BSACKR ) 

An Acknowledge response (ACK) is generated if the slave unit 
is currently capable of accepting a bus transfer from the master 
unit. 

Wait Response (BSWAIT) 

A Wait response (WAIT) is generated if the slave unit is tem- 
porarily busy and cannot accept a transfer, but will be able to 
accept the transfer after a brief delay. On receipt of the WAIT 
signal, the master unit generates continual retries until the 
transfer is completed. 

Negative Acknowledge Response (BSNAKR) 

A Negative Acknowledge response (NAK) is generated if the 
slave unit cannot accept a transfer. On receipt of the NAK sig- 
nal, the master unit does not attempt a retry. 

No Response (ACK, NAK, or WAIT) 

If no unit on the bus recognizes a transfer, no response oc- 
curs. Under these conditions, the CPU (which monitors all bus 
transfer) awaits a legitimate signal for approximately 5 micro- 
seconds, after which time it clears the bus with a NAK signal; 
the NAK signal is generated by the setting of the Bus Time-Out 
flip-flop in the CPU logic. 

4,10,6 Megabus Registers 

The Megabus registers consist of two procedure buffers (PI 
and P2) and one data buffer (BD). 

4.10.6.1 PI and P2 Buffers 

The PI and P2 buffers (BIPUO through BIP11F and BIP210 
through BIP21F) receive procedure words from the Megabus as a 
result of double-word requests. Sixteen bits are received from 
Megabus data lines through 15, while the remaining four bits 
are loaded from two integrity bits (BSREDD and BSYELO) and two 
parity bits (BSDPCO and BSDP08) . 

The PI and P2 buffers are loaded by the signals My Second 
Half PI and P2 (MYSHP1 and MYSHP2, respectively). MYSHPl is 
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generated when the first BSSHBC signal is received by the CPU, 
and MYSHP2 is generated when the second BSSHBC signal is 
received - 

The PI and P2 buffers are unloaded onto the internal bus by 
signals Enable PI to BI or Enable P2 to BI (ENP1BI and ENP2BI, 
respectively) . 

The signal PRTAKC controls which register is unloaded onto 
the bus during a Procedure Stall operation. If PRTAKC is true, 
ENP1BI is forced true and the PI buffer is unloaded; if PRTAKC 
is false, ENP2BI is forced true and the P2 buffer is unloaded. 

The 20-bit output of the PI buffer is labeled Bus Internal 
P110 through IF (BIP110 through BIP11F) , integrity signals Red 
and Yellow (BIP1RD through BIP1YL) and Parity signals 8 and 
(BIP1P8 and BIP1P0) - The 20-bit output of the P2 buffer is 
labeled BIP210 through BIP21F, BIP2RD and BIP2YL, and BIP2P8 
and BIP2P0. 

4. 10.6.2 BD Buffer 

The BD buffer, like the PI and P2 buffers, receives as input 
from the Megabus BSDTOO through BSDT15, BSREDD and BSYELO, and 
BSDP08 and BSDP00. The operand data from the Megabus is dis- 
tributed throughout the CPU via the internal bus. The BD buffer 
is loaded by My Second Half Read (MYSHRD) when the BSSHBC signal 
is received by the CPU during a single fetch operation. It is 
unloaded onto the internal bus by Enable Data Buffer to BI 
(ENDTBI), which comes true when the Data Stall (CRDSTL) signal 
is true. 

The 20-bit output from the BD buffer is labeled BrDTIO 
through BIDT1F, BIDTRD, BIDTYL, BIDT08, and BIDT00. 

4.11 INTERRUPT CONTROL LOGIC 

The interrupt control logic is divided into three areas: 

• Address compare logic 

• Level check logic 

• Interrupt register. 

4.11.1 Address Compare Logic (see Figure 4-1 1) 

An interrupt message on the Megabus is accepted for examina- 
tion by the CPU if the currently active data cycle (enabled by 
the interrupt requesting unit) has not been initiated by the CPU 
itself and does not require a memory reference. If these condi- 
tions are satisfied, the Bus Address Compare (BSACMP) signal en- 
ables a comparison of the CPU internal channel identification 
number (supplied by the hexadecimal rotary switch) and Megabus 
address bits 14 through 17 (least significant four bits of slave 
unit channel number) to determine if the interrupt message is 
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intended for this CPU. If the compare operation is successful 
(A=B) and Megabus address bits 8 through 13 equal Zero (indi- 
cating a CPU type channel number), a CPU address compare signal 
is generated and fed to the strobe select circuits to partici- 
pate in determining whether the Megabus format reflects a second 
half bus cycle or an external interrupt* A second half bus cycle 
generates the Second Half Cycle Strobe signal (MYSHCS) which. In 
turn, sets the Second Half Read Cycle Flop (MYSHRC) . An external 
interrupt generates the Interrupt Strobe signal (MYINTS) which, 
in turn, sets the Interrupt Received flop (MYINTR) , providing a 
clock signal for both the negative acknowledge response and in- 
terrupt flip-flops (refer to subsection 4.11.2). 

At this point, a decision is made to either accept the in- 
terrupt for service by allowing the interrupt flip-flop to set, 
or to delay acceptance by allowing the negative acknowledge re- 
sponse flip-flop to set. The decision is based on a comparison 
of the interrupt request's priority level to the current operat- 
ing level of the CPU, and the state of the interrupt busy flip- 
flop (refer to subsection 4.11.2). 

4.11.2 Level Check Logic 

The level check logic (see Figure 4-12) compares Megabus data 
bits 10 through 15 (level of incoming request), S register bits 
10 through 15 (current CPU operating level), and the state of the 
Interrupt Busy flip-flop (MYINTB) . If the priority of the in- 
coming request is equal to or lower than the current operating 
level of the CPU and/or the interrupt busy flip-flop is set (in- 
dicating that the CPU is currently servicing a previous inter- 
rupt), the output from the comparator sets the No Acknowledge 
Response flip-flop (MYNAKR) , delaying acceptance of the inter- 
rupt. However, if the incoming priority level is higher than the 
current CPU operating level and the interrupt busy flip-flop is 
not set, the comparator output sets the Interrupt flop-flip 
(MYINTF) . At this point, the interrupt is accepted and the 
interrupt busy flip-flop is set. 

The interrupt busy flip-flop is also set when a power failure 
occurs and the CPU is not operating at the hghest (zero) priority 

level . 

4.11.3 Interrupt Register 

The interrupt register (see Figure 4-13) receives the level 
of the incoming interrupt request over Megabus data lines 10 
through 15 when the interrupt request is accepted by the CPU 
(i.e., when the interrupt flip-flop is set). This action allows 
firmware to process the request subsequent to an acknowledgment. 
Also, if the Megabus format reflects a second half bus cycle 
rather than an external interrupt request, Megabus da*.,: lines 10 
through 15 are fed to the Megabus data buffer when the second 
half read cycle flip-flop is set. 
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Figure 4-11 Address Compare Logic 
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The output from the interrupt register (BINN10 through 
BINN1F) is delivered to the internal bus by the Enable Interrupt 
to BI (ENINBI) signal, indicating that the CPU is ready to ser- 
vice the interrupt. 
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Figure 4-13 Interrupt Register 
4.12 FULL CONTROL PANEL 

This subsection provides a description of the full control 
panel physical characteristics and principles of operation, A 
description of the basic control panel is not included because 
its limited operating controls and indicators are similar to 
the corresponding full panel controls and indicators (refer to 
subsection 2,1. 9. 9.1). To obtain a comprehensive understanding 
of each basic panel control and indicator function, the reader 
should reference the applicable diagrams for the basic control 
panel and the corresponding text for the full control panel. 
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NOTE 

The material contained herein assumes that a 
full control panel is connected to an opera- 
tional CPU, the CPU is powered up, and the 
panel is active (unlocked). 

4.12.1 Physical Characteristics 

The control panel is a self-contained unit, consisting of one 
control and one logic board. The control switches, system sta- 
tus, and register display indicators are mounted on the control 
board; their associated circuit components and configurations are 
mounted on the logic board. The control switches, status indi- 
cators, and display indicators are as follows (see Figure 2-2 for 
the physical location of each component) : 

• POWER on/off switch 

• PANEL SECURITY lock/unlock 

• LOCATION display (register address) 

• CONTENTS display (register data) 

• CPU controls and indicators 

• Key-pad array. 

Four connectors provide the direct signal interface connec- 
tion between both boards (see Figure 4-14) ♦ The rocker arm 
switch assembly is mounted on the logic board (refer to Table 2-1 
for correct switch settings). in addition, the logic board con- 
nects to the CPU with a 44-wire connector and to the PANEL 
SECURITY switch with a 6-wire connector. The 44-wire pin-to-pin 
cable connections are shown in Figure 4-15. The PANEL SECURITY 
and POWER switches are connected to the panel frame on the left 
side of the control board. 

4.12.2 Principles of Operation 

Figure 4-16 illustrates the data flow, control signal de- 
velopment, and signal interface between the CPU and control 
panel, and should be referred to throughout the text as needed. 
The principal elements of the panel are the key-pad array and 
the LOCATION/CONTENTS display. All other elements support each 
register and key-pad, and produce the control panel internal and 
CPU interface control signals. 
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Figure 4-14 Interconnections and Rocker Arm Switch Assembly 
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Figure 4-15 Control Panel to CPU Signal Cable Connections 
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4-12.2-1 Control Panel Functionality 

All control panel activity is governed by CPU firmware to al- 
low manual operations from the panel when the CPU is in its Stop 
state, and to automatically update the respective control panel 
displays and indicators at 8-mill isecond intervals when the CPU 
is in its Run state- Also, with the CPU in its Run state, the 
firmware acknowledges the following two manual functions from the 
panel to permit selection of an addressable CPU register for dis- 
play in the panel displays, or to stop the CPU for manual 
intervention : 

• Select mode: Manual selection via the Select (S) 
pushbutton 

• Stop mode: Manual selection via the STOP (S) pushbutton. 

All data and signal communication between the CPU and control 
panel is through 16 Internal Bus (BI) and 28 unique control panel 
transmission lines. The CPU gates (ENMPBI) panel data (see Table 
4-5) onto the internal bus, and simultaneously gates (ENRDSP) ad- 
dress data from the internal bus into the control panel LOCATION 
display. All data character transfers between the panel and in- 
ternal bus are controlled by specific control panel selections 
(e.g., Read or Write Memory) and the resident CPU control panel 
firmware. 

Table 4-5 Control Panel to CPU Internal Bus Bit Assignments 



BIT(S) 


FUNCTIONS 


REMARKS 


0-3 


CPU register data 


From panel data bus 


4 


Run mode (true); Stop 
mode (false) 


— 


5 


Panel location 
reg ister data 


Refer to bits 8 and 12 through 15 


6 


Increment (true) ; 
Non increment (false) 


- 


7 


Change mode (true); 
Select mode (false) 


— 


8 


Panel location 

r eg ister data 


Refer to bits 5 and 12 through 15 


9 


Write mode (true); 
Read mode (false) 


— 


10 


N/A 


Ground 


12-15 

I 


Panel location 

register data 


Refer to bits 5 and 8 
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4.12.2.2 Data Input Devices 

A key-pad array and a Test and Verification Loader (TVL) pro- 
vide a user with two optional data input devices to the CPU. The 
TVL is primarily intended to load diagnostic programs from a tape 
cassette into main memory. For a complete explanation of the 
TVL, refer to the Type LDU9101 Test and Verification Loader Man- 
ual (Order No. FL97) . 

Sixteen single-action pushbutton switches (keys) comprise the 
key-pad array. Each key is assigned a unique hexadecimal char- 
acter (i.e., through 9/A through F) that is inscribed on its 
keycap; the keys are used to input data to a hexadecimal encoder. 
Activating a key (keystroke) generates its corresponding hexa- 
decimal character code (MPHEX1 through MPHEX4) and a unique key- 
stroke (MPHEXS) signal at the encoder output to form a register 
address or a hexadecimal data character to modify a register. 
For further details on the key-pad array, refer to the discussion 
en ti tied Select /Change Modes in subsecton 4.12. 2. 4« 3. 

4.12.2.3 Register Displays 

The location and contents indicator fields from the control 
panel display network enable the user to interrogate or modify 
any of the selected CPU registers (see Table 2-2) . 

4.12.2.3.1 LOCATION Display 

The LOCATION display consists of two hexadecimal indicator 
assemblies that are designed to display hexadecimal characters 
HI and H2. Both indicators monitor the internal bus to display 
(ENRDSP) the selected CPU register address that resides in the 
control panel location register (see Figure 4-16). 

4.12.2.3.2 CONTENTS Display 

The CONTENTS display consists of five hexadecimal indicators 
(H4 through H8) as shown in Figure 4-16, and is designed to dis- 
play the hexadecimal character contents of a CPU addressable 16- 
bit or 20-bit register (see Table 2-2). Data is stored into the 
display from internal bus bits through 15 when the Display 
Latch Enable (MPDLAT) and/or the Display Upper Latch (MPDULT) 
command is received and decoded in the panel. 

4. 12. 2. 4 Panel Controls/Indicators 

To implement a panel initiate CPU operation, the CPU at pre- 
determined intervals gates, via ENMPBI, the key-pad output and 
current panel status (see Table 4-5) onto the internal bus for 
firmware interrogation and implementation of one of the following 
CPU operational modes: 
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• Stop/Ready/Run 

• Read/Write Memory 

• Select/Change 

• Plus 1 (Increment) Plus (Non-Increment) - 

Concurrent with the preceding operations, the CPU has a fifth 
operational mode called LAF/SAF. In this mode, the CPU monitors 
the panel transmission lines to condition itself for or to imple- 
ment one of the following panel initiated CPU operations: 

• Load/Restart 

• Execute. 

The manner in which each panel status condition, its corre- 
sponding operation, and the associated indicators are activated 
is described in subsequent paragraphs. A description of two 
specific CPU status indicators (CHECK and DC ON) and the opera- 
tion of the Clear (CLR) pushbutton is provided in Table 2-1. 

4,12.2.4.1 Stop/Ready/Run Modes 

Run mode enables the CPU to process instructions. To enter 
the Run mode, the CPU must first be initialized to its Stop 

(MPSTOP) state and the panel Ready (MPREDY) signal must be acti- 
vated- Stop mode allows manual intervention and single instruc- 
tion execution from the panel, and is activated by depressing the 
Stop (S) pushbutton (MPPBST) . This causes the CPU to complete 

its current instruction and to perform the following: 

• Halt all memory resident program processing activity 

• Enter a continuous panel service loop 

• Clear the RUN, READY, and TRAFFIC indicators 

• Update the Instruction (DO) register with the next in- 
struction for execution 

• Equate the program counter to one greater than the next 
instruction memory location address 

• Illuminate the STOP/STEP indicator. 

To enter the Ready state, depress the control panel Ready (R) 
pushbutton (MPRUNN); this illuminates the Ready indicator and en- 
ables both the RUN and TRAFFIC indicators. Depressing the EXE- 
CUTE (E) pushbutton causes the CPU to process instructions, be- 
ginning with the instruction contained in the CPU instruction (F) 
register. Then the CPU control panel firmware generates a 
Traffic Set (MPTRAC) command, which is decoded in the panel to 
illuminate the RUN indicator, and to illuminate the TRAFFIC indi- 
cator. The Ready/Run states are also activated when a panel or 
CPU initiated Load operation is implemented. 
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4.12.2.4.2 Read/Write Mode 

The following two control panel prerequisites are assumed 
completed by the user: 

• The Increment (Plus l)/Nonincreraent (Plus 0) mode is en- 
abled (refer to the following discussion). 

• The Memory Address (AO) and Bus Data (BO) registers are 
initialized (refer to the TVL manual*) for the proper dis 
play in the LOCATION and CONTENTS displays, respectively. 

Activating a contr ol pan el Read (R) or Write (W; op eration; 
(1) clears Increment (MPINCR) and CPU Stop mode [MPSTOP) , (2) 
conditions, via MPMEMA, the CPU for a Read/Write memory cycle 
through the internal bus and (3) illuminates the selected READ 
or WRITE indicator- Also f activating Write (MPWRWO) clears the 
control panel Load/Restart state. Depressing the Execute (E) 
pushbutton initiates a CPU memory cycle to perform a pr eselect ed 
control panel Read or Write operation, A Read memory (MPWRITE) 
cycle fetches data from a preselected memory location and stores 
it in the bus data register (CONTENTS display). A Write memory 
(MPWRITE) cycle takes data from the bus data register and stores 
it in a preselected memory location. Each successive depression 
of the Execute (E) pushbutton repeats a Read or Write memory cy- 
cle at the same or next sequential memory location as determined 
by the Plus 1 (Increment) /Plus (Nonincrement) pushbutton 
selection , 

4.12.2.4.3 Select/Change Modes 

The Select/Change modes allow a user to select r display, and 
modify (from the key-pad array) selected CPU registers as de- 
scribed in the following text. Visual display of a register ad- 
dress and its contents is provided in the LOCATION and CONTENTS 
displays , respectively. 

Select Mode 

Activating Select (S) mode: (1) clears change (C) mode 
(MPCHGR) , (2) extinguishes the CHANGE indicator, and (3) noti- 
fies the CPU control panel f i rmwa re through the CPU internal 
bus. It also enables, via MPCHNG, the location register to ac- 
cept key-pad data to form one of 49 register addresses (see 
Table 2-2 and Figure 4-17). 

To form a legitimate CPU register address, the location reg- 
ister is configured to accept alpha hexadecimal characters 8 
through F in its leftmost character position (HI), and numeric 
hexadecimal characters through 7 in its rightmost character 



*The TVL manual is entitled: Type LDU9101 Test and Verification 
Loader Manual (Order No. FL97) . 
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position (H2) . Each additional depression of an alphanumeric 
character overlays a character in its respective location regis- 
ter position. This operation is allowed in both the CPU Stop and 
Run modes. 

Change Mode 

Activating Change (C) mode (MPCHNG): (1) clears Select mode, 
(2) illuminates the CHANGE indicator, and {3) notifies firmware 
through the internal bus. It also allows a user to change the 
contents of the following addressable CPU registers: AO, BO 
through B7, DO through D7 , and EO. All remaining addressable CPU 
registers (e.g., CO through C7) are read only type registers. 
Only 4 characters are needed to fill the data registers {DO 
through D7). Base register (BO) requires just 4 characters when 
used as the source data in a memory panel write operation. The 
remaining changeable registers (A0 r Bl through B7, and EO) are 
designated as address registers and 5 characters are entered when 
filling the selected register from the control panel. 

Key-pad input activity to a selected CPU register occurs in 
the following manner and can be observed in the CONTENTS display. 
Depressing characters through F activates, via MPHEXS, a 6- 
mill isecond debounce network, which generates a 1 . 6-microsecond 
(MPS0S2) pulse. This is to allow sufficient time to stabilize 
any keystroke line transients and to activate a CPU flag (MPCHGR) 
that is required by the firmware to process a data character. 
With each depression of a key: (1) the CPU shifts all four/five 
data characters in the selected CPU register left by one charac- 
ter position, (2) truncates the leftmost character (H4) , and (3) 
stores the corresponding character in the rightmost character 
position <H8). This process is repeated for each subsequent de- 
pression of a key. 

NOTE 

Refer to Table 2-2 in determining the number of 
characters required to fill the selected register. 
To avoid entering the wrong data r exercise care 
when entering the desired data pattern. 

4.12.2.4.4 I ncrement/Non- Increment Functi ons 

The Increment (MPPOW0+, Plus 1) and Nonincrement (MPPBP0+, 
Plus 0) panel functions enable firmware to initiate a Nonincre- 
ment or Increment Read/Write memory operation with each depres- 
sion of the EXECUTE (E) pushbutton. Hence, a Read/Write memory 
cycle is performed at each new sequential memory address in an 
Increment operation (i.e.. Plus 1 is on), or at the same memory 
address in a Nonincrement operation (i.e.. Plus is on). 
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4.12.2.4.5 Long/Short Address Form (LAF/SAF) 

The central processor monitors the address mode (LAF/SAF) 
which is controlled by switch 4 of the rocker arm switch assem- 
bly. Switch 4 set to the LAF position, followed by a master 
clear (e.g., powering up or depressing CLR pushbutton), will 
cause the CPU address development to be 20 bits in length. 
Switch 4 set to the SAF position, followed by a master clear, 
causes the address fields to be 16 bits in length. 

NOTE 

With the portable panel and the basic panel installed 
in the same system, address mode control takes place 
in the basic panel. When LAF mode is selected, it 
will be displayed on both the portable panel and the 
basic panel. 

4.12.2.4.6 Load/Restart Operation 

Two fundamental CPU start-up operations, called Load and 
Restart, are included in the system to manually or automatically 
load a program (Bootstrap), or to restart the CPU from a pre- 
determined memory location. A manual program Load (MPLOAD) is 
enabled with Stop mode active (MPRUNN) and when the control 
panel Load (L) pushbutton (MPPBLD) is depressed. Actual execu- 
tion commences with the depression of the Execute (E) push- 
button. This causes the CPU to load a program from the program 
designated input device (Default operation) or from a user- 
selected input device. In a Default operation, a system Quality 
Logic Test (MPQLTA) is included and is implemented with the first 
depression of the Execute <E) pushbutton. This illuminates, via 
BSQLTA, the CHECK indicator, which is extinguished when the test 
is successfully completed {see Table 2-1). Depressing the Exe- 
cute (E) pushbutton a second time implements the loading of a 
program from the default device. A user may select an alternate 
input device after the Quality Logic Test (QLT) has been com- 
pleted. First, depress the Stop (S) pushbutton and alter the 
contents of Data register 1 (Dl) to the desired BOOT channel 
number. Then, in sequence, depress the Ready (R) and Execute 
(E) pushbuttons. When the preceding load activity is success- 
fully concluded, both the RUN (MPRUNN) and the TRAFFIC (MPTRAF) 
indicators are illuminated. 

When the PANEL SECURITY switch is on (MPLOCK) or a basic 
panel is installed, an automatic program load or CPU restart se- 
quence is available. The sequence is designed to automatically 
restart an unattended CPU when ac source power is restored to 
the CPU after a power failure. In a CPU with a non-volatile 
memory (e.g., core memory or memory save power supply), program 
restart commences at memory location C. When the CPU contains a 
volatile memory (VOLMEM-) , the Default Load operation previously 
described is performed. When auto boot is performed, the Memory 
QLT (lower 8K) will be executed. When auto restart is performed, 
the Memory QLT will be bypassed. 
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NOTE 

If both the portable panel and the basic panel 

are installed in the same system, auto boot/ 

auto restart control takes place in the basic 
panel . 

4,12,2,4.7 Execute Operation 

The Execute (E) pushbutton is enabled when the Stop mode and 
the panel are active to initiate one of the following panel se- 
lected operations in the CPU: 

• Read/Write Memory 

• Execute Single Instruction 

• Program Load/Restart. 

Depressing the Execute (E) pushbutton sends a 1- 6-raicrosecond 
strobe pulse, 6-milliseconds after its initial depression, to the 
CPU to allow firmware to implement the selected function. 

4.12.2.5 Panel Lock Request 

The control panel, when active and requiring service (e.g., 

display update, register change, mode change), transmits its 

locked state to the CPU. The 8-millisecond update cycle is con- 
trolled internally by the CPU when in the Run mode. 
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